Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ENH: pad: add delegation #72

Draft
wants to merge 3 commits into
base: main
Choose a base branch
from

Conversation

lucascolley
Copy link
Collaborator

@lucascolley lucascolley commented Dec 26, 2024

closes gh-69

@lucascolley lucascolley changed the title ENH: add pad ENH: pad: add delegation Dec 26, 2024
@lucascolley
Copy link
Collaborator Author

lucascolley commented Dec 26, 2024

@ev-br this is what I'm thinking. Of course, for only 1 function here this overcomplicates things, but I think we will see the benefits of cleanly separating which files are using the standard API and which are using library-specific functions, if/when more delegation is added. And it leaves the door open for more "smart" delegation if that would become appropriate.

I'd like to leave this as draft until gh-53 is merged, as that PR adds a way to test with existing array libraries (and this one would cause merge conflicts anyway if we did that here first).

@lucascolley lucascolley added enhancement New feature or request delegation labels Dec 26, 2024
Copy link
Contributor

@ev-br ev-br left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So the main points are:

  • you effectively whitelist the kernels as opposed to a catch-all delegating to xp.pad. An unknown backend will get a 'generic' implementation instead of being asked for a pad namespaced function. Makes sense.
  • the approach is way more light-touch than in scipy.{signal,ndimage,special}: in there you need either a delegation dict or a whole module. Here it's simple enough to keep the if-elif chain inside an affected function. Would be straightforward to refactor if a need arises.

A really minor point is the _delegators.py name: in scipy this only contains the _signature functions, and the kernels are elsewhere. Here this module contains the public symbol(s) including the if-elif delegation chains. This is fine though, and will also be simple to refactor if the need arises (that's a big fat if here).

My other inline comments are all optional and minor.

Concluding, this refactor LGTM.

is_numpy_namespace,
is_torch_namespace,
)
from ._lib._utils._typing import Array, ModuleType
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit, optional: importing stdlib things from _utils three levels deep makes it look like there's something tricky on top of stdlib imports. I'd just import them as needed from stdlib.

Copy link
Collaborator Author

@lucascolley lucascolley Dec 26, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

True for ModuleType, but since Array is "custom", I'd rather leave it like this I think. Then whenever we can start using things from array-api-typing, only that file needs to change.

EDIT: thinking that through, maybe we should have something like ArrayNamespace which can alias to ModuleType for now. But let's see how array-api-typing goes.

EDIT 2: I agree now that we should just import ModuleType from stdlib here

# `array-api-compat` to override the import location

try:
from ...._array_api_compat_vendor import ( # pyright: ignore[reportMissingImports]
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Four dots, srsly

Copy link
Collaborator Author

@lucascolley lucascolley left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

TO-DO here:

  • adjust scope section of the docs
  • rename _delegation.py to _delegation.py
  • add pad to the api reference
  • figure out where the function docstrings should live
  • test the delegation

follow-up:

  • add a section on adding delegation to the contributor docs
  • open a tracker for adding delegation to functions

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
delegation enhancement New feature or request
Projects
None yet
Development

Successfully merging this pull request may close these issues.

ENH: add pad
2 participants